<template>
    <el-form ref="form" :model="user" :rules="rules" label-width="80px">
        <el-form-item :label="$t('user.index.098976-11')" prop="nickName">
            <el-input style="width: 60%" v-model="user.nickName" maxlength="30" />
        </el-form-item>
        <el-form-item :label="$t('user.index.098976-13')" prop="phonenumber">
            <el-input style="width: 60%" v-model="user.phonenumber" maxlength="11" />
        </el-form-item>
        <el-form-item :label="$t('user.index.098976-19')" prop="email">
            <el-input style="width: 60%" v-model="user.email" maxlength="50" />
        </el-form-item>
        <el-form-item :label="$t('user.userInfo.560923-1')">
            <el-radio-group v-model="user.sex">
                <el-radio label="0">{{ $t('user.userInfo.560923-2') }}</el-radio>
                <el-radio label="1">{{ $t('user.userInfo.560923-3') }}</el-radio>
            </el-radio-group>
        </el-form-item>
        <el-form-item>
            <el-button type="primary" size="mini" @click="submit">{{ $t('save') }}</el-button>
            <el-button type="danger" size="mini" @click="close">{{ $t('close') }}</el-button>
        </el-form-item>
    </el-form>
</template>

<script>
import { updateUserProfile } from '@/api/system/user';

export default {
    props: {
        user: {
            type: Object,
        },
    },
    data() {
        return {
            // 表单校验
            rules: {
                nickName: [{ required: true, message: this.$t('user.index.098976-33'), trigger: 'blur' }],
                email: [
                    { required: true, message: this.$t('user.userInfo.560923-0'), trigger: 'blur' },
                    {
                        type: 'email',
                        message: this.$t('user.index.098976-37'),
                        trigger: ['blur', 'change'],
                    },
                ],
                phonenumber: [
                    { required: true, message: this.$t('user.index.098976-38'), trigger: 'blur' },
                    {
                        pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/,
                        message: this.$t('user.index.098976-39'),
                        trigger: 'blur',
                    },
                ],
            },
        };
    },
    methods: {
        submit() {
            this.$refs['form'].validate((valid) => {
                if (valid) {
                    updateUserProfile(this.user).then((response) => {
                        this.$modal.msgSuccess(this.$t('updateSuccess'));
                    });
                }
            });
        },
        close() {
            this.$tab.closePage();
        },
    },
};
</script>
